CLAIM AMENDMENTS 



Claim Amendment Summary 

Claims pending 

• Before this Amendment: Claims 1-37. 

• After this Amendment: Claims 1-37. 
Non-Elected, Canceled, or Withdrawn claims: None. 
Amended claims: 1, 4-9, 11, 20, 27, 33. 

New claims: None 



Claims: 

1. (currently amended) A method comprising: 

listening at an application programming interface for a notification 
indicating that a change is to be made in a topology of streaming media 
software components; and 

when the notification is received, notifying a media engine, wherein: 
the media engine is capable of reconfiguring the topology in accordance 
with the indicated change to form a reconfigured topology : and 

at least one of the topology or the reconfigured topology have: one 
saM streaming media software component located on a computing device; 
and another sm4 streaming media software component located on another 
computing device. 
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2. (original) The method as described in claim 1, wherein the notification 
is provided by an operating system. 

3. (original) The method as described in claim 1, wherein the notification 
is provided by an application. 

4. (currently amended) The method as described in claim 1, wherein the 
notification is provided by one or more seM streaming media software 
components of the topology. 

5. (currently amended) The method as described in claim 1, wherein the 
change includes at least one of adding or removing one or more seM streaming 
media software components to the topology. 

6. (currently amended) The method as described in claim 1, wherein the 
change includes at least one of adding or removing one or more said streaming 
media software components to the topology that render the streaming media. 

7. (currently amended) The method as described in claim 1, wherein the 

change includes at least one of adding or removing one or more saM streaming 
media software components to the topology that source the streaming media. 
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8. (currently amended) The method as described in claim 1, wherein the 
change includes at least one of adding or removing one or more seki streaming 
media software components to the topology that handle the streaming media. 

9. (currently amended) The method as described in claim 1, wherein the 
topology of streaming media software components include: 

one or more media sources individual ones of which serving as a source of 
the streaming media; 

one or more transforms communicatively linked with the one or more 
media sources and configured to handle the streaming media from the one or 
more media sources; and 

one or more media sinks configured to sink the streaming media from the 
one or more transforms. 

10. (original) The method as described in claim 1, further comprising 
registering to receive the notification from an operating system. 

11. (currently amended) The method as described in claim 1, further 
comprising initializing the reconfigured topology to have an execution state 
relative to the streaming media that matches an execution state of the topology 
ef when the notification was received. 



Serial No.: 10/828,402 

Atty Docket No.: MSI -2031US 



-4- 



12. (original) The method as described in claim 11, wherein each said 
execution state includes execution characteristics that relate to the streaming 
media and are selected from the group consisting of: start; pause; stop; fast 
forward; rewind; slow motion; and position in the streaming media. 

13. (original) One or more computer readable media comprising computer 
executable instruction that, when executed on a computer, direct the computer 
to perform the method as described in claim 1. 

14. (original) A method comprising: 

listening at an application programming interface for a notification 
indicating that a change is to be made to a first topology of software 
components that is: capable of streaming media; and has an execution state 
relative to the streaming media; 

reconfiguring the first topology in accordance with the indicated change to 
form a second said topology; and 

initializing the second said topology to have an execution state that 
matches the execution state of the first topology, wherein at least one of the first 
or the second said topology have said software components that are distributed 
on a plurality of computing devices. 

15. (original) The method as described in claim 14, wherein the plurality of 
computing devices is communicatively coupled via a network. 
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16. (original) The method as described in claim 14, wherein the at least one 
of the first or second topology have said software components that are 
distributed on a plurality of computing devices such that: one said software 
component is located on a first said computing device; and another said software 
component is located on a second said computing device. 

17. (original) The method as described in claim 14, wherein each said 
execution state includes execution characteristics that relate to the streaming 
media and are selected from the group consisting of: start; pause; stop; fast 
forward; rewind; slow motion; and position in the streaming media. 

18. (original) The method as described in claim 14, further comprising 
registering to receive the notification from an operating system. 

19. (original) One or more computer readable media comprising computer 
executable instruction that, when executed on a computer, direct the computer 
to perform the method as described in claim 14. 

20. (currently amended) One or more computer readable media 
comprising computer executable instruction that, when executed on a computer, 
direct the computer to: 

listen at an application programming interface for a notification from at 

least one software component included in a topology of said software 
components, wherein the notification indicates that a change is to be made to 
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the topology that includes: one or more media sources individual ones of which 
serving as a source of a media stream; 

one or more transforms communicatively linked with the one or more 
media sources and configured to handle the media stream from the one or more 
media sources; and one or more media sinks configured to sink the media 
stream from the one or more transforms; and 

when the notification is received, notify a media engine for reconfiguring 
the topology in accordance with the indicated change to form a reconfigured 
topology , wherein at least one of the topology or the reconfigured topology have 
respective said software components that are distributed on a plurality of 
computing devices. 

21. (original) The one or more computer readable media as described in 
claim 20, wherein the API is further configured to receive the notification from at 
least one of an application or an operating system. 

22. (original) The one or more computer readable media as described in 
claim 20, wherein the change includes at least one of adding or removing one or 
more said sofl3/vare components to the topology that at least one of source or 
render the streaming media. 

23. (original) The one or more computer readable media as described in 
claim 20, wherein the plurality of computing devices is communicatively coupled 
via a network. 
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24. (original) The one or more computer readable media as described in 
claim 20, further comprising registering to receive the notification from an 
operating system. 

25. (original) The one or more computer readable media as described in 
claim 20, further comprising initializing the reconfigured topology to have an 
execution state relative to the streaming media that matches an execution state 
of the topology of when the notification was received. 

26. (original) The one or more computer readable media as described in 
claim 25, wherein each said execution state includes execution characteristics 
that relate to the streaming of the media and are selected from the group 
consisting of: start; pause; stop; fast forward; rewind; slow motion; and position 
in the streaming of the media. 

27. (currently amended) A system comprising: 
a media source providing a plurality of media; 

a computing device including one or more applications[[;]] and an 
infrastructure layer that provides an application programming interface (API) that 

is callable by the one or more applications to indicate that a change is to be 
made in a first topology of software components capable of streaming media, 
wherein: 

the infrastructure layer, in response to the indication, reconfigures the first 
topology to form a second topology; and at least one of the topology or the 
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reconfigured topology have: one said software component located on a 
computing device; and another said software component located on another 
computing device. 

28. (original) The system as described in claim 27, wherein the API is 
callable by one or more said software components to indicate the change. 

29. (original) The system as described in claim 27, wherein the API is 
callable by an operating system that is executable on at least one said computing 
device. 

30. (original) The system as described in claim 27, wherein the 
infrastructure layer registers with an operating system to receive a notification 
that indicates the change. 

31. (original) The system as described in claim 27, wherein the computing 
device is communicatively coupled to the other computing device via an Internet. 

32. (original) The system as described in claim 27, wherein the 
infrastructure layer is configured to register with an operating system to receive 
a notification that indicates the change. 
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33. (currently amended) A system comprising: 

a media source providing a plurality of media; and 

a computing device including one or more applications[[;]Lan operating 
system[;] and an infrastructure layer that provides an application programming 
interface (API) that is callable by the one or more applications or the operating 
system to: indicate that a change is to be made in a first topology of software 
components that: is capable of streaming one or more said media; and has an 
execution state relative to the streaming of the one or more said media; 
reconfigure the first topology in accordance with the indicated change to form a 
second topology; and initialize the second topology to have an execution state 
that matches the execution state of the first topology, wherein at least one of 
the first or second topology have: one said software component located on a 
computing device; and another said software component located on another 
computing device. 

34. (original) The system as described in claim 33, wherein the 
infrastructure layer is configured to register with an operating system: that is 
executable on the computing device or the other computing device; and to 
receive a notification that indicates the change. 

35. (original) The system as described in claim 33, wherein the API is 
further callable by one or more said software components to indicate the change. 
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36. (original) The system as described in claim 33, wlierein the computing 
device is communicatively coupled to the other computing device via an Internet. 

37. (original) The system as described in claim 33, wherein each said 
execution state includes execution characteristics that relate to the streaming of 
the one or more said media and that are selected from the group consisting of: 
start; pause; stop; fast forward; rewind; slow motion; and position in the 
streaming of the one or more said media. 
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